<?php
declare (strict_types=1);

namespace app\sysuser\controller\core;

use app\common\controller\SysBackend;
use app\common\model\banxi\core\CoreVocabularyRange;
use app\common\model\banxi\core\CoreVocabularySetting as CoreVocabularySettingModel;
use think\db\exception\DbException;
use think\exception\ValidateException;
use think\facade\Validate;
use think\validate\ValidateRule;

class CoreVocabularySetting extends SysBackend
{
    protected array $noNeedLogin = [];
    protected array $noNeedPermission = [];

    public function initialize(): void
    {
        parent::initialize();
        $this->model = new CoreVocabularySettingModel();
    }


    /**
     * 分页查询
     * @return void
     * @throws DbException
     */
    public function listPage(): void
    {
        $param = $this->request->param(['index', 'limit', 'orderBy', "query"]);
        //查询条件解析
        $where = get_query($param);
        //获取分页数据
        $pageParams = get_page_params($param);
        $list = $this->model->with(['rangeList'])
            ->where($where)
            ->order(['id' => 'asc'])
            ->paginate([
                'page' => $pageParams['page'],
                'list_rows' => $pageParams['limit']
            ]);
        $this->ok('操作成功', result_row($list));
    }

    /**
     * 查询
     * @return void
     * @throws \think\db\exception\DataNotFoundException
     * @throws \think\db\exception\DbException
     * @throws \think\db\exception\ModelNotFoundException
     */
    public function get()
    {
        $param = $this->request->param(["query" => []]);
        if (empty($param['query'])) {
            $this->fail('请传递你要查询的记录');
        }
        $where = get_query($param);
        $info = $this->model
            ->with(['rangeList'])
            ->where($where)
            ->find();
        if (empty($info)) {
            $this->fail('记录不存在');
        }
        $this->ok('操作成功', removeNull($info));
    }

    public function saveOrUpdate()
    {
        $param = $this->request->param();
        try {
            $id = $param['id'] ?? null;
            $info = $this->model->where(['id' => $id])->find();
            if ($info) {
                $info->save($param);
                $rangeList = $param['rangeList'] ?? [];
                $coreVocabularyRange = new CoreVocabularyRange();
                foreach ($rangeList as $item) {
                    $rangInfo = $coreVocabularyRange->where(['id' => $item['id']])->find();
                    if ($rangInfo) {
                        $rangInfo->save($item);
                    }
                }
            }
        } catch (ValidateException $exception) {
            $this->fail($exception->getMessage());
        }
        $this->ok('操作成功', [], self::NOTIFICATION);
    }

    public function del()
    {
        $param = $this->request->param(['ids' => []]);
        try {
            $validate = Validate::rule([
                'ids' => ValidateRule::isRequire(null, '请选择你要删除的记录'),
            ]);
            if (!$validate->check($param)) throw new ValidateException($validate->getError());
            CoreVocabularySettingModel::destroy(function ($query) use ($param) {
                $query->whereIn('id', $param['ids']);
            });
        } catch (ValidateException $exception) {
            $this->fail($exception->getMessage());
        }
        $this->ok('操作成功', [], self::NOTIFICATION);
    }
}
